#include "cumsum_n_d.h"

using namespace Cumsum;

extern "C" __global__ __aicore__ void cumsum(GM_ADDR x, GM_ADDR axis, GM_ADDR y, GM_ADDR workspace, GM_ADDR tiling) {
    GET_TILING_DATA(tilingData, tiling);
    if (TILING_KEY_IS(101)) {
        CumsumND<float> op;
        op.Init(x, axis, y, &tilingData);
        op.Process();
    } else if (TILING_KEY_IS(201)) {
        CumsumND<half> op;
        op.Init(x, axis, y, &tilingData);
        op.Process();
    } else if (TILING_KEY_IS(301)) {
        CumsumND<int32_t> op;
        op.Init(x, axis, y, &tilingData);
        op.Process();
    } else if (TILING_KEY_IS(401)) {
        // CumsumND<int8_t> op;
        // op.Init(x, axes, y, &tilingData);
        // op.Process();
    }
}